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DETAILED ACTION 

1 . Claims 1 -20 are pending. 

Claim Rejections - 35 USC § 102 

2. The following is a quotation of the appropriate paragraphs of 35 U.S.C. 1 02 that 
form the basis for the rejections under this section made in this Office action: 

A person shall be entitled to a patent unless - 

(e) the Invention was described in (1) an application for patent, published under section 122(b), by 
another filed in the United States before the invention by the applicant for patent or (2) a patent 
granted on an application for patent by another filed in the United States before the invention by the 
applicant for patent, except that an international application filed under the treaty defined in section 
351(a) shall have the effects for purposes of this subsection of an application filed in the United States 
only if the international application designated the United States and was published under Article 21(2) 
of such treaty in the English language. 

3. Claims 1-20 are rejected under 35 U.S.C. 102(e) as being anticipated by Gunter 
et al., (Gunter), U.S. Patent Application Publication No. 2001/0011370. 

As per claim 1 , Gunter discloses a method for automatically generating 
flowcharting instructions from a source code (jj 34:1-2, "server unit 20 translates 
code 64 into flow chart 68"), comprising: 

- loading source code statements into statement records of a data 
structure, wherein each statement record contains only one of the source code 
statements (U 35:1-5, "In accordance with one embodiment of the invention server unit 
20 generates a DOT file (i.e. data structure) that contains the (source code statement 
records expressed as)... nodes and edges, in DOT syntax, relating to the graph 
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representations for flow chart 68. This DOT file is then provided to graphic drawing 
unit"), 

- identifying each branch statement contained in the statement records (fl 

34:7-1 1 , "The condition "while" in code 64 is translated to a diamond box 76. As 
illustrated two branches or edges 78 and 80 are also generated relating to the "YES" 
and "NO" conditions associated with "while" construct of code 64.", and fig. 2B), 

- determining one or more branch destinations for each of the branch 
statements flj 34:7-11, "The condition "while" in code 64 is translated to a diamond box 
76. As illustrated two branches or edges 78 and 80 are also generated relating to the 
"YES" and "NO" conditions associated with "while" construct of code 64.", and fig. 2B), 

- storing the one or more branch destinations in one or more destination 
records of the data structure, wherein the one or more destination records 
correspond to the statement record of the branch statement fl| 34:7-11, "The 
condition "while" in code 64 is translated to a diamond box 76. As illustrated two 
branches or edges 78 and 80 are also generated relating to the "YES" and "NO" 
conditions associated with "while" construct of code 64.", and fig. 2B), 

- identifying a statement type for each statement contained in the statement 
records fl| 21:3-7, "Program constructs include individual operations that together 
accomplish a software task, such as "begin" statements, "end" statements, "if 
statements, "if-then-else" statements, "wait" statements and "assignment" statements."). 
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As per claim 2, the rejection of claim 1 is incorporated and further, Gunter 
discloses maintaining a record management system of statement conventions 
comprising defined branch statement records and alternative branch statement 
records, wherein each alternative branch statement record is associated with one 
defined branch statement record ffl 34:7-1 1 , "The condition "while" in code 64 is 
translated to a diamond box 76. As illustrated two branches or edges 78 and 80 are also 
generated relating to the "YES" (i.e. branch statement record) and "NO" (i.e. alternative 
branch statement) conditions associated with "while" construct of code 64.", and fig. 2B) 

As per claim 3, the rejection of claim 2 is incorporated and further, Gunter 
discloses that the record management system of statement conventions is 
selected from a database, a spreadsheet, an array, a set of coded rules in an 
applications program and combinations thereof fll 66:5-8, "Thus, a data structure in 
file system unit 16 is created that contains information relating to all the edges (and 
nodes) in the flow chart, including the label on each edge"). 

As per claim 4, the rejection of claim 2 is incorporated and further, Gunter 
discloses finding any alternative branch statements in the statement records; and 
replacing each of the found alternative branch statements with the associated 
defined statement (H 34:7-1 1, "The condition "while" in code 64 is translated (i.e. 
replaced with) a diamond box 76. As illustrated two branches or edges 78 and 80 are 
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also generated relating to the "YES" (i.e. branch statement record) and "NO" (i.e. 
alternative branch statement) conditions associated with "while" construct of code 64"). 

As per claim 5, the rejection of claim 1 is incorporated and further, Gunter 
discloses that the source code statements are written in a computer programming 
language selected from FORTRAN, COBOL, C/C++, PASCAL, Visual Basic, and 
PERL (see fig. 2A, items 60 and 62 and associated text (e.g. H 32:1-38:10)). 

As per claim 6, the rejection of claim 1 is incorporated and further, Gunter 
discloses that the statement types are selected from decision, input, output, 
comment, computational, arithmetic, data, type, logic, start, loop, transfer and 

end (H 21:3-7, "Program constructs include individual operations that together 
accomplish a software task, such as "begin" statements, "end" statements, "if 
statements, "if-then-else" statements, "wait" statements and "assignment" statements", 
and fig. 2A, items 60 and 62 and associated text (e.g. U 32:1-38:10)). 

As per claim 7, the rejection of claim 1 is incorporated and further, Gunter 
discloses that the statement types are selected from executable statements, non- 
executable statements, and comment statements flj 21:3-7, "Program constructs 
include individual operations that together accomplish a software task, such as "begin" 
statements, "end" statements, "if statements, "if-then-else" statements, "wait" 
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statements and "assignment" statements", and fig. 2A, items 60 and 62 and associated 
text (e.g. H 32:1-38:10)). 

As per claim 8, the rejection of claim 1 is incorporated and further, Gunter 
discloses that the statement types are selected from chain statements and branch 
statements flj 21 :3-7, "Program constructs include individual operations that together 
accomplish a software task, such as "begin" statements, "end" statements, "if 
statements, "if-then-else" statements, "wait" statements and "assignment" statements", 
and fig. 2A, items 60 and 62 and associated text (e.g. 32:1-38:10)). 

As per claim 9, the rejection of claim 1 is incorporated and further, Gunter 
discloses maintaining a record management system of statement classifications 
comprising, for each source code statement type, a statement key, a statement 
format, destination locations, branch connector labels, a flowchart shape, and 
combinations thereof flf 66:5-8, "Thus, a data structure in file system unit 16 is 
created that contains information relating to all the edges (and. nodes) in the flow chart, 
including the label on each edge"). 

As per claim 10, the rejection of claim 9 is incorporated and further, Gunter 
discloses that the statement key comprises a word, a phrase, punctuation marks, 
other symbols, and combinations thereof (H 21 :3-7, "Program constructs include 
individual operations that together accomplish a software task, such as "begin" 
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statements, "end" statements, "if statements, "if-then-else" statements, "wait" 
statements and "assignment" statements (i.e. statement keys)"). 

As per claim 1 1 , the rejection of claim 9 is incorporated and further, Gunter 
discloses that the record management system of statement classifications is 
selected from a database, a spreadsheet, an array, a set of coded rules in an 
applications program, and combinations thereof fll 66:5-8, "Thus, a data structure in 
file system unit 16 is created that contains information relating to all the edges in the 
flow chart, including the label on each edge"). 

As per claim 12, the rejection of claim 1 is incorporated and further, Gunter 
discloses that the step of identifying a statement type for each of the source code 
statements contained in the statement records further comprises: 
- matching a statement key with each of the source code statements, wherein the 
statement key is associated with one statement type, and wherein the statement 
key comprises a word, a phrase, punctuation marks, other symbols, and 
combinations thereof, fl| 21:3-7, "Program constructs include individual operations 
that together accomplish a software task, such as "begin" statements, "end" statements, 
"if 1 statements, "if-then-else" statements, "wait" statements and "assignment" 
statements (i.e. statement keys)"), and recording in the data structure the statement 
type for each statement in the statement records (fl 66:5-8, "Thus, a data structure 
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in file system unit 16 is created that contains information relating to all the edges in the 
flow chart, including the label on each edge"). 

As per claim 13, the rejection of claim 12 is incorporated and further, Gunter 
discloses assigning a flowchart shape to each statement of the source code, 
wherein each flowchart shape is associated with the statement type of each 
\ statement of the source code, flj 34:1-8, "Thus, as illustrated in FIGS. 2a and 2b, 
server unit 20 translates code 64 into flow chart 68. For example, the first construct 
"begin" in code 64 is translated into a box 70 containing a text "0: START" in flow chart 
68. Similarly, the assignments of variables "y1" and "y2" are translated to assignment 
boxes 72 and 74 containing corresponding assignment texts. The condition "while" in 
code 64 is translated to a diamond box 76. As illustrated two branches or edges 78 and 
80 are also generated relating to the "YES" and "NO" conditions associated with "while" 
construct of code 64. Condition 82 of code 64 is translated to diamond box 84 in flow 
chart 66"), and storing the assigned flowchart shape in a shape record in the data 
structure corresponding to the statement record fl| 66:5-8, "Thus, a data structure 
in file system unit 16 is created that contains information relating to all the edges (and 
nodes) in the flow chart, including the label on each edge"). 

As per claim 14, the rejection of claim 1 is incorporated and further, Gunter 
discloses that the data structure is selected from a spreadsheet, a database, a 
linked list, an array and combinations thereof flj 66:5-8, "Thus, a data structure in 
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file system unit 16 is created that contains information relating to all the edges in the 
flow chart, including the label on each edge"). 

As per claim 15, the rejection of claim 1 is incorporated and further, Gunter 
discloses that the data structure is created in a computer language selected from 
COBOL, C, PASCAL and C/C.sup.++ fl[ 33:3-5, "In accordance with one embodiment 
of the invention, code 64 is written in a language that employs Pascal-like syntax, 
although the invention is not limited in scope in that respect and other languages may 
be employed in generating code"). 

As per claim 16, the rejection of claim 1 is incorporated and further, Gunter 
discloses the step of loading source code statements into statement records of a 
data structure further comprises: 

- assigning a unique statement number to each statement record (fig. 2B, all 
statements are assigned a unique statement number, e.g. item 72, "1: y:1=x", and 
associated text, flj 32:1-38:10)), 

- storing each unique statement number as a statement number record 
associated with each statement record in the data structure fl| 66:5-8, "Thus, a data 
structure in file system unit 16 is created that contains information relating to all the 
edges (and nodes) in the flow chart, including the label on each edge"). 



Application/Control Number: 10/079,255 Page 10 

Art Unit: 2122 

As per claim 17, the rejection of claim 1 is incorporated and further, Gunter 
discloses the step of determining one or more branch destinations further comprises: 

- parsing each identified branch statement to find the one or more branch 
destinations designated within the branch statement fl| 34:7-1 1 , "The condition 
"while" in code 64 is translated (i.e. replaced with) a diamond box 76. As illustrated two 
branches or edges 78 and 80 are also generated relating to the "YES" (i.e. branch 
statement record) and "NO" (i.e. alternative branch statement) conditions associated 
with "while" construct of code 64."), 

- recording the one or more branch destinations into one or more branch 
destination records contained within the data structure, wherein the branch 
destination records are associated with the identified branch statement record flj 
66:5-8, "Thus, a data structure in file system unit 16 is created that contains information 
relating to all the edges in the flow chart, including the label on each edge"), 

- recording one or more branch labels into one or more branch label 
records contained within the data structure, wherein the branch label records are 
associated with the branch destination records (U 66:5-8, "Thus, a data structure in 
file system unit 16 is created that contains information relating to all the edges in the 
flow chart, including the label on each edge"). 

As per claim 18, the rejection of claim 1 is incorporated and further, Gunter 
discloses exporting the data structure into a drawing program, wherein the data 
structure contains statement records, statement number records, destination 
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records, text branch label rec rds, and shape records; laying out shapes as 
defined in the shape records; inserting text from the statement records into the 
shapes; linking the shapes from the destination records; sizing the font to fit 
within the shapes and displaying the flowchart fl] 35:4-16, "This DOT file is then 
provided (i.e. exported) to graphic drawing unit 22 via graphical interface unit 18 to 
determine the physical layout of the nodes and edges on display unit 14. Thus, graphic 
drawing unit 22 annotates graph objects with specific coordinates. Such coordinates 
depend, among other things, on the size of display unit 14, the number of concurrent 
programs being tested, the size of each program and other physical constraints of the 
system. Once graphic drawing unit 22 completes its graph lay-out operation, it 
generates an updated DOT file that includes the physical lay-out information as well. 
The updated DOT file is then provided to graphical interface unit 18 so that it could be 
displayed on display unit"). 

As per claim 19, this is another method version of the claimed method discussed 
above, in claim 13, wherein all claimed limitations have also been addressed and/or 
cited as set forth above. For example, see Gunter's interactive software testing system 
and method fl| 32:1-38:10). 

As per claim 20, this is a computer program product version of the claimed 
method discussed above, in claim 1, wherein all claimed limitations have also been 
addressed and/or cited as set forth above. For example, see Gunter's interactive 
software testing system and method (fl 32:1-38:10). 
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Conclusion 



Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Andre R. Fowlkes whose telephone number is (571) 
272-3697. The examiner can normally be reached on Monday - Friday, 8:00am- 
4:30pm. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Tuan Q. Dam can be reached on (571)272-3695. The fax phone number for 
the organization where this application or proceeding is assigned is 703-872-9306. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 
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